#include <stdio.h>
#include <stdlib.h>

typedef struct Node
{
    int data;
    struct Node *next;
} Node, *LinkList;

bool InitList(LinkList &L)
{
    L = (Node *)malloc(sizeof(Node));
    if (L == NULL)
    {
        return false;
    }
    L->next = L;
    return true;
}

bool Empty(LinkList &L)
{
    if (L->next == L)
    {
        return true;
    }
    else
    {
        return false;
    }
}

// 判断某一结点是否是表尾结点
bool Tail(LinkList &L, Node *p)
{
    p = L->next;
    if (p == NULL || L == NULL)
    {
        return false;
    }
    if (p->next == L)
    {
        return true;
    }
    else
    {
        return false;
    }
}

int main()
{
    LinkList L;
    Node *p;
    InitList(L);
    Empty(L);
    Tail(L, p);
    return 0;
}